<!DOCTYPE html><html><head>
      <title>README</title>
      <meta charset="utf-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      
      <link rel="stylesheet" href="file:///c:\Users\zenghuijuan.HIK\.vscode\extensions\shd101wyy.markdown-preview-enhanced-0.5.22\node_modules\@shd101wyy\mume\dependencies\katex\katex.min.css">
      
      
      
      
      
      
      
      <script type="text/javascript" src="file:///c:\Users\zenghuijuan.HIK\.vscode\extensions\shd101wyy.markdown-preview-enhanced-0.5.22\node_modules\@shd101wyy\mume\dependencies\raphael\raphael.js" charset="UTF-8"></script><script type="text/javascript" src="file:///c:\Users\zenghuijuan.HIK\.vscode\extensions\shd101wyy.markdown-preview-enhanced-0.5.22\node_modules\@shd101wyy\mume\dependencies\flowchart\flowchart.min.js" charset="UTF-8"></script>
      
      <style>
      /**
 * prism.js Github theme based on GitHub's theme.
 * @author Sam Clarke
 */
code[class*="language-"],
pre[class*="language-"] {
  color: #333;
  background: none;
  font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace;
  text-align: left;
  white-space: pre;
  word-spacing: normal;
  word-break: normal;
  word-wrap: normal;
  line-height: 1.4;

  -moz-tab-size: 8;
  -o-tab-size: 8;
  tab-size: 8;

  -webkit-hyphens: none;
  -moz-hyphens: none;
  -ms-hyphens: none;
  hyphens: none;
}

/* Code blocks */
pre[class*="language-"] {
  padding: .8em;
  overflow: auto;
  /* border: 1px solid #ddd; */
  border-radius: 3px;
  /* background: #fff; */
  background: #f5f5f5;
}

/* Inline code */
:not(pre) > code[class*="language-"] {
  padding: .1em;
  border-radius: .3em;
  white-space: normal;
  background: #f5f5f5;
}

.token.comment,
.token.blockquote {
  color: #969896;
}

.token.cdata {
  color: #183691;
}

.token.doctype,
.token.punctuation,
.token.variable,
.token.macro.property {
  color: #333;
}

.token.operator,
.token.important,
.token.keyword,
.token.rule,
.token.builtin {
  color: #a71d5d;
}

.token.string,
.token.url,
.token.regex,
.token.attr-value {
  color: #183691;
}

.token.property,
.token.number,
.token.boolean,
.token.entity,
.token.atrule,
.token.constant,
.token.symbol,
.token.command,
.token.code {
  color: #0086b3;
}

.token.tag,
.token.selector,
.token.prolog {
  color: #63a35c;
}

.token.function,
.token.namespace,
.token.pseudo-element,
.token.class,
.token.class-name,
.token.pseudo-class,
.token.id,
.token.url-reference .token.variable,
.token.attr-name {
  color: #795da3;
}

.token.entity {
  cursor: help;
}

.token.title,
.token.title .token.punctuation {
  font-weight: bold;
  color: #1d3e81;
}

.token.list {
  color: #ed6a43;
}

.token.inserted {
  background-color: #eaffea;
  color: #55a532;
}

.token.deleted {
  background-color: #ffecec;
  color: #bd2c00;
}

.token.bold {
  font-weight: bold;
}

.token.italic {
  font-style: italic;
}


/* JSON */
.language-json .token.property {
  color: #183691;
}

.language-markup .token.tag .token.punctuation {
  color: #333;
}

/* CSS */
code.language-css,
.language-css .token.function {
  color: #0086b3;
}

/* YAML */
.language-yaml .token.atrule {
  color: #63a35c;
}

code.language-yaml {
  color: #183691;
}

/* Ruby */
.language-ruby .token.function {
  color: #333;
}

/* Markdown */
.language-markdown .token.url {
  color: #795da3;
}

/* Makefile */
.language-makefile .token.symbol {
  color: #795da3;
}

.language-makefile .token.variable {
  color: #183691;
}

.language-makefile .token.builtin {
  color: #0086b3;
}

/* Bash */
.language-bash .token.keyword {
  color: #0086b3;
}

/* highlight */
pre[data-line] {
  position: relative;
  padding: 1em 0 1em 3em;
}
pre[data-line] .line-highlight-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  background-color: transparent;
  display: block;
  width: 100%;
}

pre[data-line] .line-highlight {
  position: absolute;
  left: 0;
  right: 0;
  padding: inherit 0;
  margin-top: 1em;
  background: hsla(24, 20%, 50%,.08);
  background: linear-gradient(to right, hsla(24, 20%, 50%,.1) 70%, hsla(24, 20%, 50%,0));
  pointer-events: none;
  line-height: inherit;
  white-space: pre;
}

pre[data-line] .line-highlight:before, 
pre[data-line] .line-highlight[data-end]:after {
  content: attr(data-start);
  position: absolute;
  top: .4em;
  left: .6em;
  min-width: 1em;
  padding: 0 .5em;
  background-color: hsla(24, 20%, 50%,.4);
  color: hsl(24, 20%, 95%);
  font: bold 65%/1.5 sans-serif;
  text-align: center;
  vertical-align: .3em;
  border-radius: 999px;
  text-shadow: none;
  box-shadow: 0 1px white;
}

pre[data-line] .line-highlight[data-end]:after {
  content: attr(data-end);
  top: auto;
  bottom: .4em;
}html body{font-family:"Helvetica Neue",Helvetica,"Segoe UI",Arial,freesans,sans-serif;font-size:16px;line-height:1.6;color:#333;background-color:#fff;overflow:initial;box-sizing:border-box;word-wrap:break-word}html body>:first-child{margin-top:0}html body h1,html body h2,html body h3,html body h4,html body h5,html body h6{line-height:1.2;margin-top:1em;margin-bottom:16px;color:#000}html body h1{font-size:2.25em;font-weight:300;padding-bottom:.3em}html body h2{font-size:1.75em;font-weight:400;padding-bottom:.3em}html body h3{font-size:1.5em;font-weight:500}html body h4{font-size:1.25em;font-weight:600}html body h5{font-size:1.1em;font-weight:600}html body h6{font-size:1em;font-weight:600}html body h1,html body h2,html body h3,html body h4,html body h5{font-weight:600}html body h5{font-size:1em}html body h6{color:#5c5c5c}html body strong{color:#000}html body del{color:#5c5c5c}html body a:not([href]){color:inherit;text-decoration:none}html body a{color:#08c;text-decoration:none}html body a:hover{color:#00a3f5;text-decoration:none}html body img{max-width:100%}html body>p{margin-top:0;margin-bottom:16px;word-wrap:break-word}html body>ul,html body>ol{margin-bottom:16px}html body ul,html body ol{padding-left:2em}html body ul.no-list,html body ol.no-list{padding:0;list-style-type:none}html body ul ul,html body ul ol,html body ol ol,html body ol ul{margin-top:0;margin-bottom:0}html body li{margin-bottom:0}html body li.task-list-item{list-style:none}html body li>p{margin-top:0;margin-bottom:0}html body .task-list-item-checkbox{margin:0 .2em .25em -1.8em;vertical-align:middle}html body .task-list-item-checkbox:hover{cursor:pointer}html body blockquote{margin:16px 0;font-size:inherit;padding:0 15px;color:#5c5c5c;background-color:#f0f0f0;border-left:4px solid #d6d6d6}html body blockquote>:first-child{margin-top:0}html body blockquote>:last-child{margin-bottom:0}html body hr{height:4px;margin:32px 0;background-color:#d6d6d6;border:0 none}html body table{margin:10px 0 15px 0;border-collapse:collapse;border-spacing:0;display:block;width:100%;overflow:auto;word-break:normal;word-break:keep-all}html body table th{font-weight:bold;color:#000}html body table td,html body table th{border:1px solid #d6d6d6;padding:6px 13px}html body dl{padding:0}html body dl dt{padding:0;margin-top:16px;font-size:1em;font-style:italic;font-weight:bold}html body dl dd{padding:0 16px;margin-bottom:16px}html body code{font-family:Menlo,Monaco,Consolas,'Courier New',monospace;font-size:.85em !important;color:#000;background-color:#f0f0f0;border-radius:3px;padding:.2em 0}html body code::before,html body code::after{letter-spacing:-0.2em;content:"\00a0"}html body pre>code{padding:0;margin:0;font-size:.85em !important;word-break:normal;white-space:pre;background:transparent;border:0}html body .highlight{margin-bottom:16px}html body .highlight pre,html body pre{padding:1em;overflow:auto;font-size:.85em !important;line-height:1.45;border:#d6d6d6;border-radius:3px}html body .highlight pre{margin-bottom:0;word-break:normal}html body pre code,html body pre tt{display:inline;max-width:initial;padding:0;margin:0;overflow:initial;line-height:inherit;word-wrap:normal;background-color:transparent;border:0}html body pre code:before,html body pre tt:before,html body pre code:after,html body pre tt:after{content:normal}html body p,html body blockquote,html body ul,html body ol,html body dl,html body pre{margin-top:0;margin-bottom:16px}html body kbd{color:#000;border:1px solid #d6d6d6;border-bottom:2px solid #c7c7c7;padding:2px 4px;background-color:#f0f0f0;border-radius:3px}@media print{html body{background-color:#fff}html body h1,html body h2,html body h3,html body h4,html body h5,html body h6{color:#000;page-break-after:avoid}html body blockquote{color:#5c5c5c}html body pre{page-break-inside:avoid}html body table{display:table}html body img{display:block;max-width:100%;max-height:100%}html body pre,html body code{word-wrap:break-word;white-space:pre}}.markdown-preview{width:100%;height:100%;box-sizing:border-box}.markdown-preview .pagebreak,.markdown-preview .newpage{page-break-before:always}.markdown-preview pre.line-numbers{position:relative;padding-left:3.8em;counter-reset:linenumber}.markdown-preview pre.line-numbers>code{position:relative}.markdown-preview pre.line-numbers .line-numbers-rows{position:absolute;pointer-events:none;top:1em;font-size:100%;left:0;width:3em;letter-spacing:-1px;border-right:1px solid #999;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.markdown-preview pre.line-numbers .line-numbers-rows>span{pointer-events:none;display:block;counter-increment:linenumber}.markdown-preview pre.line-numbers .line-numbers-rows>span:before{content:counter(linenumber);color:#999;display:block;padding-right:.8em;text-align:right}.markdown-preview .mathjax-exps .MathJax_Display{text-align:center !important}.markdown-preview:not([for="preview"]) .code-chunk .btn-group{display:none}.markdown-preview:not([for="preview"]) .code-chunk .status{display:none}.markdown-preview:not([for="preview"]) .code-chunk .output-div{margin-bottom:16px}.scrollbar-style::-webkit-scrollbar{width:8px}.scrollbar-style::-webkit-scrollbar-track{border-radius:10px;background-color:transparent}.scrollbar-style::-webkit-scrollbar-thumb{border-radius:5px;background-color:rgba(150,150,150,0.66);border:4px solid rgba(150,150,150,0.66);background-clip:content-box}html body[for="html-export"]:not([data-presentation-mode]){position:relative;width:100%;height:100%;top:0;left:0;margin:0;padding:0;overflow:auto}html body[for="html-export"]:not([data-presentation-mode]) .markdown-preview{position:relative;top:0}@media screen and (min-width:914px){html body[for="html-export"]:not([data-presentation-mode]) .markdown-preview{padding:2em calc(50% - 457px + 2em)}}@media screen and (max-width:914px){html body[for="html-export"]:not([data-presentation-mode]) .markdown-preview{padding:2em}}@media screen and (max-width:450px){html body[for="html-export"]:not([data-presentation-mode]) .markdown-preview{font-size:14px !important;padding:1em}}@media print{html body[for="html-export"]:not([data-presentation-mode]) #sidebar-toc-btn{display:none}}html body[for="html-export"]:not([data-presentation-mode]) #sidebar-toc-btn{position:fixed;bottom:8px;left:8px;font-size:28px;cursor:pointer;color:inherit;z-index:99;width:32px;text-align:center;opacity:.4}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] #sidebar-toc-btn{opacity:1}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc{position:fixed;top:0;left:0;width:300px;height:100%;padding:32px 0 48px 0;font-size:14px;box-shadow:0 0 4px rgba(150,150,150,0.33);box-sizing:border-box;overflow:auto;background-color:inherit}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar{width:8px}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar-track{border-radius:10px;background-color:transparent}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar-thumb{border-radius:5px;background-color:rgba(150,150,150,0.66);border:4px solid rgba(150,150,150,0.66);background-clip:content-box}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc a{text-decoration:none}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc ul{padding:0 1.6em;margin-top:.8em}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc li{margin-bottom:.8em}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc ul{list-style-type:none}html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{left:300px;width:calc(100% -  300px);padding:2em calc(50% - 457px -  150px);margin:0;box-sizing:border-box}@media screen and (max-width:1274px){html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{padding:2em}}@media screen and (max-width:450px){html body[for="html-export"]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{width:100%}}html body[for="html-export"]:not([data-presentation-mode]):not([html-show-sidebar-toc]) .markdown-preview{left:50%;transform:translateX(-50%)}html body[for="html-export"]:not([data-presentation-mode]):not([html-show-sidebar-toc]) .md-sidebar-toc{display:none}
/* Please visit the URL below for more information: */
/*   https://shd101wyy.github.io/markdown-preview-enhanced/#/customize-css */

      </style>
    </head>
    <body for="html-export">
      <div class="mume markdown-preview  ">
      <ul>
<li><a href="#h5player">h5player</a>
<ul>
<li><a href="#%E6%8F%8F%E8%BF%B0">&#x63CF;&#x8FF0;</a></li>
<li><a href="#%E7%89%88%E6%9C%AC">&#x7248;&#x672C;</a></li>
<li><a href="#%E5%AA%92%E4%BD%93%E7%89%88%E6%9C%AC%E9%99%90%E5%88%B6">&#x5A92;&#x4F53;&#x7248;&#x672C;&#x9650;&#x5236;</a></li>
<li><a href="#%E4%BD%BF%E7%94%A8%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9">&#x4F7F;&#x7528;&#x6CE8;&#x610F;&#x4E8B;&#x9879;</a></li>
<li><a href="#%E6%B5%8F%E8%A7%88%E5%99%A8%E9%99%90%E5%88%B6%E4%BB%A5%E5%8F%8A%E7%BC%96%E8%A7%A3%E7%A0%81%E6%94%AF%E6%8C%81%E6%83%85%E5%86%B5">&#x6D4F;&#x89C8;&#x5668;&#x9650;&#x5236;&#x4EE5;&#x53CA;&#x7F16;&#x89E3;&#x7801;&#x652F;&#x6301;&#x60C5;&#x51B5;</a></li>
<li><a href="#%E6%8E%A5%E5%8F%A3%E8%B0%83%E7%94%A8%E6%B5%81%E7%A8%8B%E5%9B%BE">&#x63A5;&#x53E3;&#x8C03;&#x7528;&#x6D41;&#x7A0B;&#x56FE;</a></li>
<li><a href="#%E5%BC%95%E5%85%A5">&#x5F15;&#x5165;</a></li>
<li><a href="#%E5%88%9B%E5%BB%BA%E5%AE%9E%E4%BE%8B">&#x521B;&#x5EFA;&#x5B9E;&#x4F8B;</a></li>
<li><a href="#%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E">&#x63A5;&#x53E3;&#x8BF4;&#x660E;</a>
<ul>
<li><a href="#%E4%BA%8B%E4%BB%B6%E5%88%9D%E5%A7%8B%E5%8C%96-js_setwindowcontrolcallbackevents">&#x4E8B;&#x4EF6;&#x521D;&#x59CB;&#x5316;: JS_SetWindowControlCallback(events)</a></li>
<li><a href="#play">&#x64AD;&#x653E;: JS_Play(url, config, windowIndex, startTime, endTime)</a></li>
<li><a href="#stop">&#x505C;&#x6B62;&#x64AD;&#x653E;: JS_Stop(windowIndex)</a></li>
<li><a href="#%E5%81%9C%E6%AD%A2%E6%89%80%E6%9C%89%E6%92%AD%E6%94%BE-js_stoprealplayall">&#x505C;&#x6B62;&#x6240;&#x6709;&#x64AD;&#x653E;: JS_StopRealPlayAll()</a></li>
<li><a href="#%E5%BC%80%E5%90%AF%E5%A3%B0%E9%9F%B3-js_opensoundwindowindex">&#x5F00;&#x542F;&#x58F0;&#x97F3;: JS_OpenSound(windowIndex)</a></li>
<li><a href="#%E5%85%B3%E9%97%AD%E5%A3%B0%E9%9F%B3-js_closesoundwindowindex">&#x5173;&#x95ED;&#x58F0;&#x97F3;: JS_CloseSound(windowIndex)</a></li>
<li><a href="#%E8%AE%BE%E7%BD%AE%E9%9F%B3%E9%87%8F-js_setvolumewindowindex-volumn">&#x8BBE;&#x7F6E;&#x97F3;&#x91CF;: JS_SetVolume(windowIndex, volumn)</a></li>
<li><a href="#%E8%8E%B7%E5%8F%96%E5%BD%93%E5%89%8D%E9%9F%B3%E9%87%8F-js_getvolumewindowindex">&#x83B7;&#x53D6;&#x5F53;&#x524D;&#x97F3;&#x91CF;: JS_GetVolume(windowIndex)</a></li>
<li><a href="#%E5%BD%95%E5%83%8F-js_startsaveexwindowindex-filename-idsttype">&#x5F55;&#x50CF;: JS_StartSaveEx(windowIndex, fileName, idstType)</a></li>
<li><a href="#%E5%81%9C%E6%AD%A2%E5%BD%95%E5%83%8F%E5%B9%B6%E4%BF%9D%E5%AD%98%E6%96%87%E4%BB%B6-js_stopsavewindowindex">&#x505C;&#x6B62;&#x5F55;&#x50CF;&#x5E76;&#x4FDD;&#x5B58;&#x6587;&#x4EF6;: JS_StopSave(windowIndex)</a></li>
<li><a href="#%E6%8A%93%E5%9B%BE-js_capturepicturewindowindex-filename-filetype-callback">&#x6293;&#x56FE;: JS_CapturePicture(windowIndex, fileName, fileType, callback)</a></li>
<li><a href="#%E5%9B%9E%E6%94%BEjs_playplay">&#x56DE;&#x653E;&#xFF1A;JS_Play()</a></li>
<li><a href="#%E5%81%9C%E6%AD%A2%E5%9B%9E%E6%94%BEjs_stopstop">&#x505C;&#x6B62;&#x56DE;&#x653E;&#xFF1A;JS_Stop()</a></li>
<li><a href="#%E6%9A%82%E5%81%9C%E5%9B%9E%E6%94%BE-js_pausewindowindex">&#x6682;&#x505C;&#x56DE;&#x653E;: JS_Pause(windowIndex)</a></li>
<li><a href="#%E6%81%A2%E5%A4%8D%E5%9B%9E%E6%94%BE-js_resumewindowindex">&#x6062;&#x590D;&#x56DE;&#x653E;: JS_Resume(windowIndex)</a></li>
<li><a href="#%E5%BC%80%E5%A7%8B%E5%AF%B9%E8%AE%B2-js_starttalksztalkurl">&#x5F00;&#x59CB;&#x5BF9;&#x8BB2;: JS_StartTalk(szTalkUrl)</a></li>
<li><a href="#%E5%81%9C%E6%AD%A2%E5%AF%B9%E8%AE%B2-js_stoptalk">&#x505C;&#x6B62;&#x5BF9;&#x8BB2;: JS_StopTalk()</a></li>
<li><a href="#%E8%AE%BE%E7%BD%AE%E5%AF%B9%E8%AE%B2%E9%9F%B3%E9%87%8Fjs_talksetvolumenvolume">&#x8BBE;&#x7F6E;&#x5BF9;&#x8BB2;&#x97F3;&#x91CF;&#xFF1A;JS_TalkSetVolume(nVolume)</a></li>
<li><a href="#%E8%8E%B7%E5%8F%96%E5%AF%B9%E8%AE%B2%E9%9F%B3%E9%87%8F-js_talkgetvolume">&#x83B7;&#x53D6;&#x5BF9;&#x8BB2;&#x97F3;&#x91CF;: JS_TalkGetVolume()</a></li>
<li><a href="#%E5%BD%95%E5%83%8F-%E6%8A%93%E5%9B%BE%E5%8A%9F%E8%83%BD%E5%90%8C%E9%A2%84%E8%A7%88%E6%92%AD%E6%94%BE">&#x5F55;&#x50CF;&#x3001;&#x6293;&#x56FE;&#x529F;&#x80FD;&#x540C;&#x9884;&#x89C8;&#x64AD;&#x653E;</a></li>
<li><a href="#%E5%9B%9E%E6%94%BE%E5%BF%AB%E6%94%BE-js_fastwindowindex">&#x56DE;&#x653E;&#x5FEB;&#x653E;: JS_Fast(windowIndex)</a></li>
<li><a href="#%E5%9B%9E%E6%94%BE%E6%85%A2%E6%94%BE-js_slowwindowindex">&#x56DE;&#x653E;&#x6162;&#x653E;: JS_Slow(windowIndex)</a></li>
<li><a href="#%E5%9B%9E%E6%94%BE%E5%AE%9A%E4%BD%8D-js_seekwindowindex-strattime-endtime">&#x56DE;&#x653E;&#x5B9A;&#x4F4D;: JS_Seek(windowIndex, stratTime, endTime)</a></li>
<li><a href="#%E5%9B%9E%E6%94%BE%E5%8D%95%E5%B8%A7%E8%BF%9B%E9%AB%98%E7%BA%A7%E6%A8%A1%E5%BC%8F%E5%8A%9F%E8%83%BD-js_frameforwardwindowindex">&#x56DE;&#x653E;&#x5355;&#x5E27;&#x8FDB;&#xFF08;&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x529F;&#x80FD;&#xFF09;: JS_FrameForward(windowIndex)</a></li>
<li><a href="#%E7%94%B5%E5%AD%90%E6%94%BE%E5%A4%A7%E9%AB%98%E7%BA%A7%E6%A8%A1%E5%BC%8F%E5%8A%9F%E8%83%BD-js_enablezoomwindowindex">&#x7535;&#x5B50;&#x653E;&#x5927;&#xFF08;&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x529F;&#x80FD;&#xFF09;: JS_EnableZoom(windowIndex)</a></li>
<li><a href="#%E5%BC%80%E5%90%AF%E5%85%B3%E9%97%AD%E6%99%BA%E8%83%BD%E4%BF%A1%E6%81%AF%E5%B1%95%E7%A4%BA%E9%AB%98%E7%BA%A7%E6%A8%A1%E5%BC%8F%E5%8A%9F%E8%83%BD-js_renderallprivatedataiwndnum-bopenflag">&#x5F00;&#x542F;/&#x5173;&#x95ED;&#x667A;&#x80FD;&#x4FE1;&#x606F;&#x5C55;&#x793A;&#xFF08;&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x529F;&#x80FD;&#xFF09;: JS_RenderALLPrivateData(iWndNum, bOpenFlag)</a></li>
<li><a href="#%E5%88%86%E5%B1%8F-js_arrangewindowsplitnum">&#x5206;&#x5C4F;: JS_ArrangeWindow(splitNum)</a></li>
<li><a href="#%E6%95%B4%E4%BD%93%E5%85%A8%E5%B1%8F-js_fullscreendisplayisfull">&#x6574;&#x4F53;&#x5168;&#x5C4F;: JS_FullScreenDisplay(isFull)</a></li>
<li><a href="#%E5%8D%95%E7%AA%97%E5%8F%A3%E5%85%A8%E5%B1%8F-js_fullscreensinglewindowindex">&#x5355;&#x7A97;&#x53E3;&#x5168;&#x5C4F;: JS_FullScreenSingle(windowIndex)</a></li>
<li><a href="#%E8%AE%BE%E7%BD%AE%E7%AA%97%E5%8F%A3%E5%A4%A7%E5%B0%8Fjs_resize-iwidth-iheight">&#x8BBE;&#x7F6E;&#x7A97;&#x53E3;&#x5927;&#x5C0F;&#xFF1A;JS_Resize (iWidth, iHeight)</a></li>
<li><a href="#%E8%8E%B7%E5%8F%96osd%E6%97%B6%E9%97%B4js_getosdtime-windowindex">&#x83B7;&#x53D6;OSD&#x65F6;&#x95F4;&#xFF1A;JS_GetOSDTime (windowIndex)</a></li>
<li><a href="#%E8%8E%B7%E5%8F%96%E9%9F%B3%E8%A7%86%E9%A2%91%E4%BF%A1%E6%81%AFjs_getvideoinfo-windowindex">&#x83B7;&#x53D6;&#x97F3;&#x89C6;&#x9891;&#x4FE1;&#x606F;&#xFF1A;JS_GetVideoInfo (windowIndex)</a></li>
<li><a href="#%E8%AE%BE%E7%BD%AE%E5%8F%96%E6%B5%81%E8%BF%9E%E6%8E%A5%E8%B6%85%E6%97%B6%E6%97%B6%E9%97%B4js_setconnecttimeout-windowindex-ntime">&#x8BBE;&#x7F6E;&#x53D6;&#x6D41;&#x8FDE;&#x63A5;&#x8D85;&#x65F6;&#x65F6;&#x95F4;&#xFF1A;JS_SetConnectTimeOut (windowIndex, nTime)</a></li>
</ul>
</li>
<li><a href="#%E9%94%99%E8%AF%AF%E7%A0%81%E5%8F%8A%E5%85%B6%E6%8F%8F%E8%BF%B0">&#x9519;&#x8BEF;&#x7801;&#x53CA;&#x5176;&#x63CF;&#x8FF0;</a></li>
<li><a href="#faq">FAQ</a></li>
</ul>
</li>
</ul>
<h1 class="mume-header" id="h5player">h5player</h1>

<h2 class="mume-header" id="%E6%8F%8F%E8%BF%B0">&#x63CF;&#x8FF0;</h2>

<p>h5player&#x662F;&#x4E00;&#x4E2A;&#x57FA;&#x4E8E;HTML5&#x7684;&#x6D41;&#x5F0F;&#x7F51;&#x7EDC;&#x89C6;&#x9891;&#x64AD;&#x653E;&#x5668;&#xFF0C;&#x65E0;&#x9700;&#x5B89;&#x88C5;&#x6D4F;&#x89C8;&#x5668;&#x63D2;&#x4EF6;&#x5373;&#x53EF;&#x901A;&#x8FC7;websocket&#x534F;&#x8BAE;&#x5411;&#x5A92;&#x4F53;&#x670D;&#x52A1;&#x53D6;&#x6D41;&#x64AD;&#x653E;&#x591A;&#x79CD;&#x683C;&#x5F0F;&#x7684;&#x97F3;&#x89C6;&#x9891;&#x6D41;&#x3002;</p>
<h2 class="mume-header" id="%E7%89%88%E6%9C%AC">&#x7248;&#x672C;</h2>

<p>&#x5F53;&#x524D;&#x7248;&#x672C; 2.0.0</p>
<h2 class="mume-header" id="%E5%AA%92%E4%BD%93%E7%89%88%E6%9C%AC%E9%99%90%E5%88%B6">&#x5A92;&#x4F53;&#x7248;&#x672C;&#x9650;&#x5236;</h2>

<p>&#x5A92;&#x4F53;&#x7F51;&#x5173;:mgc_V5.11.101003 &#x6216; mgc_V5.13.100&#x7248;&#x672C;&#x53CA;&#x4EE5;&#x4E0A;</p>
<h2 class="mume-header" id="%E4%BD%BF%E7%94%A8%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9">&#x4F7F;&#x7528;&#x6CE8;&#x610F;&#x4E8B;&#x9879;</h2>

<p>1&#x3001;&#x9700;&#x8981;&#x5728;web&#x670D;&#x52A1;&#x5668;&#x8FD4;&#x56DE;&#x7684;&#x54CD;&#x5E94;&#x5934;&#x589E;&#x52A0;&#x8DE8;&#x57DF;&#x9694;&#x79BB;&#x5B57;&#x6BB5;&#xFF1A;Cross-Origin-Embedder-Policy: require-corp Cross-Origin-Opener-Policy: same-origin &#x5E76;&#x5728;https&#x73AF;&#x5883;&#x4E0B;&#x4F7F;&#x7528;&#x3002;&#x5426;&#x5219;&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x65E0;&#x6CD5;&#x4F7F;&#x7528;<br>
2&#x3001;&#x5728;&#x96C6;&#x6210;&#x8FC7;&#x7A0B;&#x4E2D;new JSPlugin&#x65F6;&#x5019;&#x5FC5;&#x586B;szBasePath: &apos;./dist&apos;, // &#x5FC5;&#x586B;,&#x5F15;&#x7528;H5player.min.js&#x7684;js&#x76F8;&#x5BF9;&#x8DEF;&#x5F84;&#xFF0C;&#x5426;&#x5219;&#x4F1A;&#x5F15;&#x8D77;&#x5185;&#x90E8;&#x52A0;&#x8F7D;&#x89E3;&#x7801;&#x5E93;&#x5F02;&#x5E38;</p>
<h2 class="mume-header" id="%E6%B5%8F%E8%A7%88%E5%99%A8%E9%99%90%E5%88%B6%E4%BB%A5%E5%8F%8A%E7%BC%96%E8%A7%A3%E7%A0%81%E6%94%AF%E6%8C%81%E6%83%85%E5%86%B5">&#x6D4F;&#x89C8;&#x5668;&#x9650;&#x5236;&#x4EE5;&#x53CA;&#x7F16;&#x89E3;&#x7801;&#x652F;&#x6301;&#x60C5;&#x51B5;</h2>

<p>&#x4EE5;&#x4E0B;&#x6570;&#x636E;&#x90FD;&#x662F;&#x5728;pc chrome80+&#x6D4B;&#x8BD5;&#x6240;&#x5F97;</p>
<table>
<thead>
<tr>
<th style="text-align:center">&#x89E3;&#x7801;&#x65B9;&#x5F0F;</th>
<th style="text-align:center">&#x6D4F;&#x89C8;&#x5668;&#x9650;&#x5236;</th>
</tr>
</thead>
<tbody>
<tr>
<td style="text-align:center">&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;</td>
<td style="text-align:center">&#x5F53;&#x524D;&#x652F;&#x6301; Chrome80+&#xFF0C;ios safari,andriod browser</td>
</tr>
<tr>
<td style="text-align:center">&#x666E;&#x901A;&#x6A21;&#x5F0F;</td>
<td style="text-align:center">&#x9664; IE &#x548C; IOS Safari &#x5916;&#xFF0C;&#x57FA;&#x672C;&#x90FD;&#x652F;&#x6301;</td>
</tr>
</tbody>
</table>
<table>
  <tbody><tr>
    <th rowspan="2">&#x89E3;&#x7801;&#x65B9;&#x5F0F;</th>
    <th colspan="2">&#x89C6;&#x9891;&#x7F16;&#x7801;&#x683C;&#x5F0F;</th>
    <th colspan="8">&#x97F3;&#x9891;&#x7F16;&#x7801;&#x683C;&#x5F0F;</th>
  </tr>
  <tr>
    <td>H264</td>
    <td>H265</td>
    <td>AAC</td>
    <td>AACLD</td>
    <td>ADPCM</td>
    <td>G711</td>
    <td>G722_1</td>
    <td>G726</td>
    <td>MP2</td>
    <td>Opus</td>
  </tr>
  <tr align="middle">
    <td>&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
  </tr>
  <tr align="middle">
    <td>&#x666E;&#x901A;&#x6A21;&#x5F0F;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2713;</td>
    <td>&#x2715;</td>
    <td>&#x2715;</td>
    <td>&#x2715;</td>
    <td>&#x2715;</td>
    <td>&#x2715;</td>
    <td>&#x2715;</td>
    <td>&#x2715;</td>
  </tr>
</tbody></table>
<table>
  <tbody><tr>
    <th rowspan="3">&#x89E3;&#x7801;&#x65B9;&#x5F0F;</th>
    <th rowspan="3">&#x89C6;&#x9891;&#x7F16;&#x7801;&#x683C;&#x5F0F;</th>
    <th rowspan="3">&#x5206;&#x8FA8;&#x7387;</th>
    <th rowspan="3">&#x89C6;&#x9891;&#x53C2;&#x6570;(bps*fps)</th>
    <th colspan="3">&#x89E3;&#x7801;&#x8DEF;&#x6570;&#xFF08;&#x7CFB;&#x7EDF;&#xFF1A;Win7&#xFF09;</th>
  </tr>
  <tr>
    <th>CPU&#xFF1A;<br>I7_8700K</th>
    <th>CPU&#xFF1A;<br>I5-9400/F</th>
    <th>CPU&#xFF1A;<br>I3-8100</th>
  </tr>
  <tr>
    <th>&#x663E;&#x5361;&#xFF1A;RTX2080</th>
    <th>&#x663E;&#x5361;&#xFF1A;GTX1050TI</th>
    <th>&#x663E;&#x5361;&#xFF1A;GT1030D5</th>
  </tr>
  <tr align="middle">
    <td rowspan="4">&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;</td>
    <td rowspan="2">H265</td>
    <td>1080P</td>
    <td>4M * 25</td>
    <td>6</td>
    <td>4</td>
    <td>3</td>
  </tr>
  <tr align="middle">
    <td>720P</td>
    <td>2M * 25</td>
    <td>14</td>
    <td>10</td>
    <td>6</td>
  </tr>
  <tr align="middle">
    <td rowspan="2">H264</td>
    <td>1080P</td>
    <td>4M * 25 </td>
    <td>6</td>
    <td>4</td>
    <td>3</td>
  </tr>
  <tr align="middle">
    <td>720P</td>
    <td>2M * 25</td>
    <td>14</td>
    <td>10</td>
    <td>6</td>
  </tr>
  <tr align="middle">
 <td rowspan="4">&#x666E;&#x901A;&#x6A21;&#x5F0F;</td>
    <td rowspan="2">H265(&#x91C7;&#x7528;&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x89E3;&#x7801;)</td>
    <td>1080P</td>
    <td>4M * 25</td>
    <td>6</td>
    <td>4</td>
    <td>3</td>
  </tr>
  <tr align="middle">
    <td>720P</td>
    <td>2M * 25</td>
    <td>14</td>
    <td>10</td>
    <td>6</td>
  </tr>
  <tr align="middle">
    <td rowspan="2">H264</td>
    <td>1080P</td>
    <td>4M * 25</td>
    <td>24</td>
    <td>20</td>
    <td>9</td>
  </tr>
  <tr align="middle">
    <td>720P</td>
    <td>2M * 25</td>
    <td>32</td>
    <td>32</td>
    <td>16</td>
  </tr>
</tbody></table>
<h2 class="mume-header" id="%E6%8E%A5%E5%8F%A3%E8%B0%83%E7%94%A8%E6%B5%81%E7%A8%8B%E5%9B%BE">&#x63A5;&#x53E3;&#x8C03;&#x7528;&#x6D41;&#x7A0B;&#x56FE;</h2>

<p>&#x5176;&#x4F59;&#x63A7;&#x5236;&#x63A5;&#x53E3;&#x8C03;&#x7528;&#x90FD;&#x5728;JS_Play&#x540E;&#x8C03;&#x7528;</p>
<div class="flow">st=&gt;start: &#x5F00;&#x59CB;
e=&gt;end: &#x7ED3;&#x675F;
op1=&gt;operation: &#x521B;&#x5EFA;&#x5B9E;&#x4F8B;&#xFF1A;new JSPlugin|past
op2=&gt;operation: &#x4E8B;&#x4EF6;&#x521D;&#x59CB;&#x5316;&#xFF1A;JS_SetWindowControlCallback|past
op3=&gt;operation: &#x8C03;&#x7528;&#x9884;&#x89C8;/&#x56DE;&#x653E;&#x63A5;&#x53E3;&#xFF1A;JS_Play|current
op4=&gt;operation: &#x8C03;&#x7528;&#x505C;&#x6B62;&#x63A5;&#x53E3;&#xFF1A;JS_Stop|current
op5=&gt;operation: &#x6293;&#x56FE;|current

st-&gt;op1-&gt;op2-&gt;op3-&gt;op4
op4-&gt;e
</div><h2 class="mume-header" id="%E5%BC%95%E5%85%A5">&#x5F15;&#x5165;</h2>

<p>&#x76F4;&#x63A5;&#x7528;&lt;script&gt;&#x6807;&#x7B7E;&#x5F15;&#x5165;</p>
<pre data-role="codeBlock" data-info class="language-"><code>&lt;!-- h5player --&gt;
&lt;script src=&quot;h5player.min.js&quot;&gt;&lt;/script&gt;
</code></pre><h2 class="mume-header" id="%E5%88%9B%E5%BB%BA%E5%AE%9E%E4%BE%8B">&#x521B;&#x5EFA;&#x5B9E;&#x4F8B;</h2>

<pre data-role="codeBlock" data-info class="language-"><code>&lt;body&gt;
  &lt;div id=&quot;play_window&quot;&gt;&lt;/div&gt;
  &lt;script&gt;
    var curIndex = 0; // &#x5F53;&#x524D;&#x7A97;&#x53E3;&#x4E0B;&#x6807;
    var myPlugin = new JSPlugin({
      szId: &apos;play_window&apos;, //&#x9700;&#x8981;&#x82F1;&#x6587;&#x5B57;&#x6BCD;&#x5F00;&#x5934; &#x5FC5;&#x586B;
      szBasePath: &apos;./dist&apos;, // &#x5FC5;&#x586B;,&#x5F15;&#x7528;H5player.min.js&#x7684;js&#x76F8;&#x5BF9;&#x8DEF;&#x5F84;

      // &#x5F53;&#x5BB9;&#x5668;div#play_window&#x6709;&#x56FA;&#x5B9A;&#x5BBD;&#x9AD8;&#x65F6;&#xFF0C;&#x53EF;&#x4E0D;&#x4F20;iWidth&#x548C;iHeight&#xFF0C;&#x7A97;&#x53E3;&#x5927;&#x5C0F;&#x5C06;&#x81EA;&#x9002;&#x5E94;&#x5BB9;&#x5668;&#x5BBD;&#x9AD8;
      // iWidth: 600,
      // iHeight: 400,

      // &#x5206;&#x5C4F;&#x64AD;&#x653E;&#xFF0C;&#x9ED8;&#x8BA4;&#x6700;&#x5927;&#x5206;&#x5C4F;4*4
      // iMaxSplit: 4,
      // iCurrentSplit: 1,

      // &#x6837;&#x5F0F;
      // oStyle: {
      //   border: &quot;#343434&quot;,
      //   borderSelect: &quot;#FFCC00&quot;,
      //   background: &quot;#000&quot;
      // }
    })
  &lt;/script&gt;
&lt;/body&gt;
</code></pre><h2 class="mume-header" id="%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E">&#x63A5;&#x53E3;&#x8BF4;&#x660E;</h2>

<h3 class="mume-header" id="%E4%BA%8B%E4%BB%B6%E5%88%9D%E5%A7%8B%E5%8C%96-js_setwindowcontrolcallbackevents">&#x4E8B;&#x4EF6;&#x521D;&#x59CB;&#x5316;: JS_SetWindowControlCallback(events)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>events</td>
<td>Object</td>
<td>&#x4E8B;&#x4EF6;&#x5BF9;&#x5E94;&#x7684;&#x5904;&#x7406;&#x51FD;&#x6570;&#x96C6;&#x5408;</td>
<td>&#x662F;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>JS_SetWindowControlCallback({
  windowEventSelect: function (index) {  //&#x63D2;&#x4EF6;&#x9009;&#x4E2D;&#x7A97;&#x53E3;&#x56DE;&#x8C03;
      curIndex = index;
      console.log(index, iErrorCode, oError);
  },
  pluginErrorHandler: function (index, iErrorCode, oError) {  //&#x63D2;&#x4EF6;&#x9519;&#x8BEF;&#x56DE;&#x8C03;
      // do you want...
  },
  windowEventOver: function (index) {  //&#x9F20;&#x6807;&#x79FB;&#x8FC7;&#x56DE;&#x8C03;
      // do you want...
  },
  windowEventOut: function (index) {  //&#x9F20;&#x6807;&#x79FB;&#x51FA;&#x56DE;&#x8C03;
      // do you want...
  },
  windowEventUp: function (index) {  //&#x9F20;&#x6807;mouseup&#x4E8B;&#x4EF6;&#x56DE;&#x8C03;
      // do you want...
  },
  windowFullCcreenChange: function (bFull) {  //&#x5168;&#x5C4F;&#x5207;&#x6362;&#x56DE;&#x8C03;
      // do you want...
  },
  firstFrameDisplay: function (index, iWidth, iHeight) {  //&#x9996;&#x5E27;&#x663E;&#x793A;&#x56DE;&#x8C03;
      // do you want...
  },
  performanceLack: function () {  //&#x6027;&#x80FD;&#x4E0D;&#x8DB3;&#x56DE;&#x8C03;
      // do you want...
  },
  StreamEnd: function () {  //&#x56DE;&#x653E;&#x7ED3;&#x675F;&#x56DE;&#x8C03;
      // do you want...
  }
});
</code></pre><h3 class="mume-header undefined" id="play">&#x64AD;&#x653E;: JS_Play(url, config, windowIndex, startTime, endTime)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>url</td>
<td>String</td>
<td>&#x6D41;&#x5A92;&#x4F53;URL</td>
<td>&#x662F;</td>
</tr>
<tr>
<td>config</td>
<td>Object</td>
<td>&#x64AD;&#x653E;&#x914D;&#x7F6E;</td>
<td>&#x6D41;&#x5A92;&#x4F53;&#x5FC5;&#x4F20;{ playURL: &apos;&apos; }</td>
</tr>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x5F53;&#x524D;&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x662F;</td>
</tr>
<tr>
<td>startTime</td>
<td>DateTime</td>
<td>&#x56DE;&#x653E;&#x5F00;&#x59CB;&#x65F6;&#x95F4;&#xFF0C;&#x683C;&#x5F0F;&#x7C7B;&#x578B;&#xFF1A;2021-06-29T00:00:00Z</td>
<td>&#x9884;&#x89C8;&#x4E0D;&#x80FD;&#x586B;&#xFF0C;&#x56DE;&#x653E;&#x5FC5;&#x586B;</td>
</tr>
<tr>
<td>endTime</td>
<td>DateTime</td>
<td>&#x56DE;&#x653E;&#x7ED3;&#x675F;&#x65F6;&#x95F4;&#xFF0C;&#x683C;&#x5F0F;&#x7C7B;&#x578B;&#xFF1A;2021-06-29T00:00:00Z</td>
<td>&#x9884;&#x89C8;&#x4E0D;&#x80FD;&#x586B;&#xFF0C;&#x56DE;&#x653E;&#x5FC5;&#x586B;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>let url = document.getElementById(&apos;url&apos;).value;
let startTime, endTime;
myPlugin.JS_Play(
  url,
  {
    playURL: url, // &#x6D41;&#x5A92;&#x4F53;&#x64AD;&#x653E;&#x65F6;&#x5FC5;&#x4F20;
    mode: 0, // &#x89E3;&#x7801;&#x7C7B;&#x578B;&#xFF1A;0=&#x666E;&#x901A;&#x6A21;&#x5F0F;; 1=&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F; &#x9ED8;&#x8BA4;&#x4E3A;0

    // &#x8BBE;&#x7F6E;&#x76F4;&#x8FDE;&#x65F6;&#x7684;&#x8BA4;&#x8BC1;&#x53C2;&#x6570;&#x7B49;
    // ...
  },
  curIndex, //&#x5F53;&#x524D;&#x7A97;&#x53E3;&#x4E0B;&#x6807;

  // &#x56DE;&#x653E;&#x53C2;&#x6570;
  startTime,
  endTime,
)
</code></pre><h3 class="mume-header undefined" id="stop">&#x505C;&#x6B62;&#x64AD;&#x653E;: JS_Stop(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x505C;&#x6B62;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_Stop(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_Stop success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_Stop failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%81%9C%E6%AD%A2%E6%89%80%E6%9C%89%E6%92%AD%E6%94%BE-js_stoprealplayall">&#x505C;&#x6B62;&#x6240;&#x6709;&#x64AD;&#x653E;: JS_StopRealPlayAll()</h3>

<p>&#x53C2;&#x6570;&#xFF1A;&#x65E0;<br>
&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_StopRealPlayAll().then(
  () =&gt; {
    console.info(&apos;JS_StopRealPlayAll success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_StopRealPlayAll failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%BC%80%E5%90%AF%E5%A3%B0%E9%9F%B3-js_opensoundwindowindex">&#x5F00;&#x542F;&#x58F0;&#x97F3;: JS_OpenSound(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5F00;&#x542F;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;&#x7684;&#x58F0;&#x97F3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_OpenSound(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_OpenSound success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_OpenSound failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%85%B3%E9%97%AD%E5%A3%B0%E9%9F%B3-js_closesoundwindowindex">&#x5173;&#x95ED;&#x58F0;&#x97F3;: JS_CloseSound(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5173;&#x95ED;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;&#x7684;&#x58F0;&#x97F3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_CloseSound(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_CloseSound success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_CloseSound failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E8%AE%BE%E7%BD%AE%E9%9F%B3%E9%87%8F-js_setvolumewindowindex-volumn">&#x8BBE;&#x7F6E;&#x97F3;&#x91CF;: JS_SetVolume(windowIndex, volumn)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x662F;</td>
</tr>
<tr>
<td>volumn</td>
<td>Number</td>
<td>&#x97F3;&#x91CF;&#x5927;&#x5C0F;</td>
<td>&#x662F;&#xFF0C;&#x8303;&#x56F4;1~100</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_SetVolume(curIndex, volumn).then(
  () =&gt; {
    console.info(&apos;JS_SetVolume success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_SetVolume failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E8%8E%B7%E5%8F%96%E5%BD%93%E5%89%8D%E9%9F%B3%E9%87%8F-js_getvolumewindowindex">&#x83B7;&#x53D6;&#x5F53;&#x524D;&#x97F3;&#x91CF;: JS_GetVolume(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x83B7;&#x53D6;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;&#x7684;&#x97F3;&#x91CF;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_GetVolume(curIndex).then(
  (volumn) =&gt; {
    console.info(&apos;JS_GetVolume success&apos;, volumn);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_GetVolume failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%BD%95%E5%83%8F-js_startsaveexwindowindex-filename-idsttype">&#x5F55;&#x50CF;: JS_StartSaveEx(windowIndex, fileName, idstType)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x662F;</td>
</tr>
<tr>
<td>fileName</td>
<td>String</td>
<td>&#x6587;&#x4EF6;&#x540D;</td>
<td>&#x662F;&#xFF0C;&#x53EF;&#x4E0D;&#x5E26;&#x540E;&#x7F00;&#xFF0C;&#x9ED8;&#x8BA4;&#x4E3A;.mp4</td>
</tr>
<tr>
<td>idstType</td>
<td>Number</td>
<td>&#x5F55;&#x50CF;&#x6587;&#x4EF6;&#x7C7B;&#x578B;</td>
<td>&#x662F;&#xFF0C;2-ps 5-mp4 ,mp4&#x5F55;&#x5236;&#x97F3;&#x9891;&#x9650;&#x5236;&#xFF0C;&#x4EC5;&#x652F;&#x6301;AAC&#x3001;G711A&#x3001;G711U</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>let fileName = &apos;fileName.mp4&apos;;
myPlugin.JS_StartSaveEx(curIndex, fileName, 2).then(
  () =&gt; {
    console.info(&apos;JS_StartSave success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_StartSave failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%81%9C%E6%AD%A2%E5%BD%95%E5%83%8F%E5%B9%B6%E4%BF%9D%E5%AD%98%E6%96%87%E4%BB%B6-js_stopsavewindowindex">&#x505C;&#x6B62;&#x5F55;&#x50CF;&#x5E76;&#x4FDD;&#x5B58;&#x6587;&#x4EF6;: JS_StopSave(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x662F;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>let fileName = &apos;fileName.mp4&apos;;
myPlugin.JS_StopSave(windowIndex).then(
  () =&gt; {
    console.info(&apos;JS_StopSave success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_StopSave failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E6%8A%93%E5%9B%BE-js_capturepicturewindowindex-filename-filetype-callback">&#x6293;&#x56FE;: JS_CapturePicture(windowIndex, fileName, fileType, callback)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x662F;</td>
</tr>
<tr>
<td>fileName</td>
<td>String</td>
<td>&#x6587;&#x4EF6;&#x540D;</td>
<td>&#x662F;</td>
</tr>
<tr>
<td>fileType</td>
<td>String</td>
<td>&#x6587;&#x4EF6;&#x7C7B;&#x578B;</td>
<td>&#x662F;&#xFF0C;&apos;BMP&apos;/&apos;JPEG&apos;</td>
</tr>
<tr>
<td>callback</td>
<td>Fuction</td>
<td>&#x56DE;&#x8C03;&#x51FD;&#x6570;</td>
<td>&#x5426;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>let fileName = &apos;img&apos;;
let fileType = &apos;BMP&apos;;
myPlugin.JS_CapturePicture(curIndex, fileName, fileType).then(
  () =&gt; {
    console.info(&apos;JS_CapturePicture success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_CapturePicture failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%9B%9E%E6%94%BEjs_playplay">&#x56DE;&#x653E;&#xFF1A;<a href="#play">JS_Play()</a></h3>

<h3 class="mume-header" id="%E5%81%9C%E6%AD%A2%E5%9B%9E%E6%94%BEjs_stopstop">&#x505C;&#x6B62;&#x56DE;&#x653E;&#xFF1A;<a href="#stop">JS_Stop()</a></h3>

<h3 class="mume-header" id="%E6%9A%82%E5%81%9C%E5%9B%9E%E6%94%BE-js_pausewindowindex">&#x6682;&#x505C;&#x56DE;&#x653E;: JS_Pause(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x6682;&#x505C;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_Pause(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_Pause success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_Pause failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E6%81%A2%E5%A4%8D%E5%9B%9E%E6%94%BE-js_resumewindowindex">&#x6062;&#x590D;&#x56DE;&#x653E;: JS_Resume(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x6062;&#x590D;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_Resume(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_Resume success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_Resume failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%BC%80%E5%A7%8B%E5%AF%B9%E8%AE%B2-js_starttalksztalkurl">&#x5F00;&#x59CB;&#x5BF9;&#x8BB2;: JS_StartTalk(szTalkUrl)</h3>

<p>&#x7279;&#x6B8A;&#x8BF4;&#x660E;&#xFF1A;&#x8BE5;&#x529F;&#x80FD;&#x53EA;&#x80FD;&#x5728;https&#x57DF;&#x4E0B;&#x4F7F;&#x7528;&#xFF0C;&#x662F;&#x6D4F;&#x89C8;&#x5668;&#x7684;&#x9650;&#x5236;<br>
&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>szTalkUrl</td>
<td>String</td>
<td>&#x5BF9;&#x8BB2;URL</td>
<td>&#x662F;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_StartTalk(szTalkUrl).then(
  () =&gt; {
    console.info(&apos;JS_StartTalk success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_StartTalk failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%81%9C%E6%AD%A2%E5%AF%B9%E8%AE%B2-js_stoptalk">&#x505C;&#x6B62;&#x5BF9;&#x8BB2;: JS_StopTalk()</h3>

<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_StopTalk().then(
  () =&gt; {
    console.info(&apos;JS_StopTalk success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_StopTalk failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E8%AE%BE%E7%BD%AE%E5%AF%B9%E8%AE%B2%E9%9F%B3%E9%87%8Fjs_talksetvolumenvolume">&#x8BBE;&#x7F6E;&#x5BF9;&#x8BB2;&#x97F3;&#x91CF;&#xFF1A;JS_TalkSetVolume(nVolume)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>nVolume</td>
<td>number</td>
<td>&#x97F3;&#x91CF;&#x5927;&#x5C0F;&#xFF08;0-100&#xFF09;</td>
<td>&#x5426;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.&#x8BBE;&#x7F6E;&#x5BF9;&#x8BB2;&#x97F3;&#x91CF;&#xFF1A;JS_TalkSetVolume(nVolume).then(
  () =&gt; {
    console.info(&apos;JS_TalkSetVolume success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_TalkSetVolume failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E8%8E%B7%E5%8F%96%E5%AF%B9%E8%AE%B2%E9%9F%B3%E9%87%8F-js_talkgetvolume">&#x83B7;&#x53D6;&#x5BF9;&#x8BB2;&#x97F3;&#x91CF;: JS_TalkGetVolume()</h3>

<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_TalkGetVolume().then(
  () =&gt; {
    console.info(&apos;JS_TalkGetVolume success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_TalkGetVolume failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%BD%95%E5%83%8F-%E6%8A%93%E5%9B%BE%E5%8A%9F%E8%83%BD%E5%90%8C%E9%A2%84%E8%A7%88%E6%92%AD%E6%94%BE">&#x5F55;&#x50CF;&#x3001;&#x6293;&#x56FE;&#x529F;&#x80FD;&#x540C;&#x9884;&#x89C8;&#x64AD;&#x653E;</h3>

<h3 class="mume-header" id="%E5%9B%9E%E6%94%BE%E5%BF%AB%E6%94%BE-js_fastwindowindex">&#x56DE;&#x653E;&#x5FEB;&#x653E;: JS_Fast(windowIndex)</h3>

<p>&#x8C03;&#x8282;&#x64AD;&#x653E;&#x500D;&#x901F;&#x4E3A;&#x5F53;&#x524D;&#x64AD;&#x653E;&#x901F;&#x5EA6;&#x7684;2&#x500D;&#xFF0C;&#x6700;&#x5927;&#x4E3A;8&#x500D;&#x3002;<br>
&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5FEB;&#x653E;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_Fast(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_Fast success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_Fast failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%9B%9E%E6%94%BE%E6%85%A2%E6%94%BE-js_slowwindowindex">&#x56DE;&#x653E;&#x6162;&#x653E;: JS_Slow(windowIndex)</h3>

<p>&#x8C03;&#x8282;&#x64AD;&#x653E;&#x500D;&#x901F;&#x4E3A;&#x5F53;&#x524D;&#x64AD;&#x653E;&#x901F;&#x5EA6;&#x7684;1/2&#x500D;&#xFF0C;&#x6700;&#x5C0F;&#x4E3A;1/8&#x500D;&#x3002;<br>
&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x6162;&#x653E;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_Slow(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_Slow success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_Slow failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%9B%9E%E6%94%BE%E5%AE%9A%E4%BD%8D-js_seekwindowindex-strattime-endtime">&#x56DE;&#x653E;&#x5B9A;&#x4F4D;: JS_Seek(windowIndex, stratTime, endTime)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x662F;</td>
</tr>
<tr>
<td>stratTime</td>
<td>DateTime</td>
<td>&#x5F00;&#x59CB;&#x65F6;&#x95F4;&#xFF0C;&#x683C;&#x5F0F;&#x7C7B;&#x578B;&#xFF1A;2021-06-29T00:00:00Z</td>
<td>&#x662F;</td>
</tr>
<tr>
<td>endTime</td>
<td>DateTime</td>
<td>&#x7ED3;&#x675F;&#x65F6;&#x95F4;&#xFF0C;&#x683C;&#x5F0F;&#x7C7B;&#x578B;&#xFF1A;2021-06-29T00:00:00Z</td>
<td>&#x662F;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_Seek(curIndex&#xFF0C;zStartDate, szEndDate).then(
  () =&gt; {
    console.info(&apos;JS_Seek success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_Seek failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%9B%9E%E6%94%BE%E5%8D%95%E5%B8%A7%E8%BF%9B%E9%AB%98%E7%BA%A7%E6%A8%A1%E5%BC%8F%E5%8A%9F%E8%83%BD-js_frameforwardwindowindex">&#x56DE;&#x653E;&#x5355;&#x5E27;&#x8FDB;&#xFF08;&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x529F;&#x80FD;&#xFF09;: JS_FrameForward(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5355;&#x5E27;&#x64AD;&#x653E;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_FrameForward(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_FrameForward success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_FrameForward failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E7%94%B5%E5%AD%90%E6%94%BE%E5%A4%A7%E9%AB%98%E7%BA%A7%E6%A8%A1%E5%BC%8F%E5%8A%9F%E8%83%BD-js_enablezoomwindowindex">&#x7535;&#x5B50;&#x653E;&#x5927;&#xFF08;&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x529F;&#x80FD;&#xFF09;: JS_EnableZoom(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5F00;&#x542F;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;&#x7684;&#x7535;&#x5B50;&#x653E;&#x5927;&#x529F;&#x80FD;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_EnableZoom(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_EnableZoom success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_EnableZoom failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%BC%80%E5%90%AF%E5%85%B3%E9%97%AD%E6%99%BA%E8%83%BD%E4%BF%A1%E6%81%AF%E5%B1%95%E7%A4%BA%E9%AB%98%E7%BA%A7%E6%A8%A1%E5%BC%8F%E5%8A%9F%E8%83%BD-js_renderallprivatedataiwndnum-bopenflag">&#x5F00;&#x542F;/&#x5173;&#x95ED;&#x667A;&#x80FD;&#x4FE1;&#x606F;&#x5C55;&#x793A;&#xFF08;&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x529F;&#x80FD;&#xFF09;: JS_RenderALLPrivateData(iWndNum, bOpenFlag)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>iWndNum</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5F00;&#x542F;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;&#x7684;&#x667A;&#x80FD;&#x4FE1;&#x606F;</td>
</tr>
<tr>
<td>bOpenFlag</td>
<td>Boolean</td>
<td>&#x5F00;&#x542F;/&#x5173;&#x95ED;</td>
<td>&#x662F;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_RenderALLPrivateData(iWndNum, true).then(
  () =&gt; {
    console.info(&apos;JS_RenderALLPrivateData success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_RenderALLPrivateData failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%88%86%E5%B1%8F-js_arrangewindowsplitnum">&#x5206;&#x5C4F;: JS_ArrangeWindow(splitNum)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>splitNum</td>
<td>Number</td>
<td>&#x5206;&#x9694;&#x6570;</td>
<td>&#x662F;&#xFF0C; &#x8303;&#x56F4;&#xFF1A;1~4</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<table>
<thead>
<tr>
<th>&#x5206;&#x9694;&#x6570;</th>
<th>&#x5206;&#x5C4F;&#x6548;&#x679C;</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1x1</td>
</tr>
<tr>
<td>2</td>
<td>2x2</td>
</tr>
<tr>
<td>3</td>
<td>3x3</td>
</tr>
<tr>
<td>4</td>
<td>4x4</td>
</tr>
</tbody>
</table>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_ArrangeWindow(splitNum).then(
  () =&gt; {
    console.info(&apos;JS_ArrangeWindow success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_ArrangeWindow failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E6%95%B4%E4%BD%93%E5%85%A8%E5%B1%8F-js_fullscreendisplayisfull">&#x6574;&#x4F53;&#x5168;&#x5C4F;: JS_FullScreenDisplay(isFull)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>isFull</td>
<td>Boolean</td>
<td>&#x662F;&#x5426;&#x5168;&#x5C4F;</td>
<td>&#x662F;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_FullScreenDisplay(true).then(
  () =&gt; {
    console.info(&apos;JS_FullScreenDisplay success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_FullScreenDisplay failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E5%8D%95%E7%AA%97%E5%8F%A3%E5%85%A8%E5%B1%8F-js_fullscreensinglewindowindex">&#x5355;&#x7A97;&#x53E3;&#x5168;&#x5C4F;: JS_FullScreenSingle(windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5168;&#x5C4F;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_FullScreenSingle(curIndex).then(
  () =&gt; {
    console.info(&apos;JS_FullScreenSingle success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_FullScreenSingle failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E8%AE%BE%E7%BD%AE%E7%AA%97%E5%8F%A3%E5%A4%A7%E5%B0%8Fjs_resize-iwidth-iheight">&#x8BBE;&#x7F6E;&#x7A97;&#x53E3;&#x5927;&#x5C0F;&#xFF1A;JS_Resize (iWidth, iHeight)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>iWidth</td>
<td>Number</td>
<td>&#x64AD;&#x653E;&#x9875;&#x9762;&#x5BBD;&#x5EA6;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x7236;&#x7A97;&#x53E3;&#x5927;&#x5C0F;</td>
</tr>
<tr>
<td>iHeight</td>
<td>Number</td>
<td>&#x64AD;&#x653E;&#x9875;&#x9762;&#x9AD8;&#x5EA6;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x7236;&#x7A97;&#x53E3;&#x5927;&#x5C0F;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_Resize().then(
  () =&gt; {
    console.info(&apos;JS_Resize success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_Resize failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E8%8E%B7%E5%8F%96osd%E6%97%B6%E9%97%B4js_getosdtime-windowindex">&#x83B7;&#x53D6;OSD&#x65F6;&#x95F4;&#xFF1A;JS_GetOSDTime (windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5168;&#x5C4F;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise<br>
&#x6210;&#x529F;&#x8FD4;&#x56DE;&#x4ECE;1970-1-1 00:00:00 &#x5230;&#x8BE5;&#x65E5;&#x671F;&#x5BF9;&#x8C61;&#x7684;&#x6BEB;&#x79D2;&#x6570;</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_GetOSDTime(curIndex).then(
  (time) =&gt; {
    console.info(&quot;osdTime:&quot;, new Date(time));
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_GetOSDTime failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E8%8E%B7%E5%8F%96%E9%9F%B3%E8%A7%86%E9%A2%91%E4%BF%A1%E6%81%AFjs_getvideoinfo-windowindex">&#x83B7;&#x53D6;&#x97F3;&#x89C6;&#x9891;&#x4FE1;&#x606F;&#xFF1A;JS_GetVideoInfo (windowIndex)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5168;&#x5C4F;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise<br>
videoInfo = {<br>
VideType: &apos;h264&apos;,  //&#x89C6;&#x9891;&#x7F16;&#x7801;&#x683C;&#x5F0F;<br>
audioType: &apos;without&apos;,//&#x97F3;&#x9891;&#x7F16;&#x7801;&#x683C;&#x5F0F;<br>
width: 0,//&#x89C6;&#x9891;&#x5206;&#x8FA8;&#x7387;&#x7684;&#x5BBD;<br>
height: 0,//&#x89C6;&#x9891;&#x5206;&#x8FA8;&#x7387;&#x7684;&#x9AD8;<br>
frameRate: 25,//&#x89C6;&#x9891;&#x5E27;&#x7387;<br>
bitRate: 2048,//&#x89C6;&#x9891;&#x7801;&#x7387;&#xFF0C;&#x5355;&#x4F4D;&#xFF1A;Kb/s<br>
systemFormt: &quot;ps&quot;//&#x89C6;&#x9891;&#x5C01;&#x88C5;&#x683C;&#x5F0F;<br>
};</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_GetVideoInfo(curIndex).then(
  (VideoInfo) =&gt; {
    console.info(&quot;VideoInfo:&quot;, VideoInfo);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_GetVideoInfo failed&apos;);
    // do you want...
  }
);
</code></pre><h3 class="mume-header" id="%E8%AE%BE%E7%BD%AE%E5%8F%96%E6%B5%81%E8%BF%9E%E6%8E%A5%E8%B6%85%E6%97%B6%E6%97%B6%E9%97%B4js_setconnecttimeout-windowindex-ntime">&#x8BBE;&#x7F6E;&#x53D6;&#x6D41;&#x8FDE;&#x63A5;&#x8D85;&#x65F6;&#x65F6;&#x95F4;&#xFF1A;JS_SetConnectTimeOut (windowIndex, nTime)</h3>

<p>&#x53C2;&#x6570;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x53C2;&#x6570;&#x540D;</th>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
<th>&#x5FC5;&#x9700;</th>
</tr>
</thead>
<tbody>
<tr>
<td>windowIndex</td>
<td>Number</td>
<td>&#x7A97;&#x53E3;&#x4E0B;&#x6807;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;&#x5168;&#x5C4F;&#x5F53;&#x524D;&#x9009;&#x4E2D;&#x7A97;&#x53E3;</td>
</tr>
<tr>
<td>nTime</td>
<td>Number</td>
<td>&#x8D85;&#x65F6;&#x65F6;&#x95F4;</td>
<td>&#x5426;&#xFF0C;&#x4E0D;&#x4F20;&#x65F6;&#x9ED8;&#x8BA4;6&#x79D2;&#xFF0C;&#x5355;&#x4F4D;&#x79D2;</td>
</tr>
</tbody>
</table>
<p>&#x8FD4;&#x56DE;&#xFF1A;Promise</p>
<pre data-role="codeBlock" data-info class="language-"><code>myPlugin.JS_SetConnectTimeOut(curIndex, nTime).then(
  () =&gt; {
    console.info(&apos;JS_SetConnectTimeOut success&apos;);
    // do you want...
  },
  (err) =&gt; {
    console.info(&apos;JS_SetConnectTimeOut failed&apos;);
    // do you want...
  }
);
</code></pre><h2 class="mume-header" id="%E9%94%99%E8%AF%AF%E7%A0%81%E5%8F%8A%E5%85%B6%E6%8F%8F%E8%BF%B0">&#x9519;&#x8BEF;&#x7801;&#x53CA;&#x5176;&#x63CF;&#x8FF0;</h2>

<table>
<thead>
<tr>
<th>&#x9519;&#x8BEF;&#x7801;</th>
<th>&#x63CF;&#x8FF0;</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x12f900001</td>
<td>&#x63A5;&#x53E3;&#x8C03;&#x7528;&#x53C2;&#x6570;&#x9519;&#x8BEF;</td>
</tr>
<tr>
<td>0x12f900002</td>
<td>&#x4E0D;&#x5728;&#x64AD;&#x653E;&#x72B6;&#x6001;</td>
</tr>
<tr>
<td>0x12f900003</td>
<td>&#x4EC5;&#x56DE;&#x653E;&#x652F;&#x6301;&#x8BE5;&#x529F;&#x80FD;</td>
</tr>
<tr>
<td>0x12f900004</td>
<td>&#x666E;&#x901A;&#x6A21;&#x5F0F;&#x4E0D;&#x652F;&#x6301;&#x8BE5;&#x529F;&#x80FD;</td>
</tr>
<tr>
<td>0x12f900005</td>
<td>&#x9AD8;&#x7EA7;&#x6A21;&#x5F0F;&#x4E0D;&#x652F;&#x6301;&#x8BE5;&#x529F;&#x80FD;</td>
</tr>
<tr>
<td>0x12f900006</td>
<td>&#x64AD;&#x653E;&#x5E93;&#x62A5;&#x9519;</td>
</tr>
<tr>
<td>0x12f900007</td>
<td>Decoder.js&#x52A0;&#x8F7D;&#x5931;&#x8D25;</td>
</tr>
<tr>
<td>0x12f910000</td>
<td>websocket&#x8FDE;&#x63A5;&#x5931;&#x8D25;&#xFF0C;&#x8BF7;&#x6838;&#x5BF9;&#x53D6;&#x6D41;URL</td>
</tr>
<tr>
<td>0x12f910010</td>
<td>&#x53D6;&#x6D41;&#x5931;&#x8D25;</td>
</tr>
<tr>
<td>0x12f910011</td>
<td>&#x6D41;&#x4E2D;&#x65AD;</td>
</tr>
<tr>
<td>0x12f910014</td>
<td>&#x6CA1;&#x6709;&#x97F3;&#x9891;&#x6570;&#x636E;</td>
</tr>
<tr>
<td>0x12f910015</td>
<td>&#x672A;&#x627E;&#x5230;&#x5BF9;&#x5E94;websocket</td>
</tr>
<tr>
<td>0x12f910016</td>
<td>websocket&#x4E0D;&#x5728;&#x8FDE;&#x63A5;&#x72B6;&#x6001;</td>
</tr>
<tr>
<td>0x12f910017</td>
<td>&#x4E0D;&#x652F;&#x6301;&#x667A;&#x80FD;&#x4FE1;&#x606F;&#x5C55;&#x793A;</td>
</tr>
<tr>
<td>0x12f910020</td>
<td>&#x5355;&#x5E27;&#x56DE;&#x653E;&#x65F6;&#x4E0D;&#x80FD;&#x6682;&#x505C;</td>
</tr>
<tr>
<td>0x12f910021</td>
<td>&#x5DF2;&#x662F;&#x6700;&#x5927;&#x500D;&#x901F;</td>
</tr>
<tr>
<td>0x12f910022</td>
<td>&#x5DF2;&#x662F;&#x6700;&#x5C0F;&#x500D;&#x901F;</td>
</tr>
<tr>
<td>0x12f920000</td>
<td>&#x50A8;&#x5B58;&#x7A7A;&#x95F4;&#x914D;&#x989D;&#x5931;&#x8D25;</td>
</tr>
<tr>
<td>0x12f920001</td>
<td>&#x8BF7;&#x6C42;&#x6587;&#x4EF6;&#x7CFB;&#x7EDF;&#x5931;&#x8D25;</td>
</tr>
<tr>
<td>0x12f920002</td>
<td>&#x83B7;&#x53D6;&#x6587;&#x4EF6;&#x5931;&#x8D25;</td>
</tr>
<tr>
<td>0x12f920003</td>
<td>&#x521B;&#x5EFA;writer&#x5931;&#x8D25;</td>
</tr>
<tr>
<td>0x12f920004</td>
<td>&#x5199;&#x6570;&#x636E;&#x5931;&#x8D25;</td>
</tr>
<tr>
<td>0x12f930000</td>
<td>&#x5185;&#x5B58;&#x4E0D;&#x8DB3;</td>
</tr>
<tr>
<td>0x12f950000</td>
<td>&#x91C7;&#x96C6;&#x97F3;&#x9891;&#x5931;&#x8D25;&#xFF0C;&#x53EF;&#x80FD;&#x662F;&#x5728;&#x975E;https/localhost&#x57DF;&#x4E0B;&#x4F7F;&#x7528;&#x5BF9;&#x8BB2;&#x5BFC;&#x81F4;</td>
</tr>
<tr>
<td>0x12f950001</td>
<td>&#x5BF9;&#x8BB2;&#x4E0D;&#x652F;&#x6301;&#x8FD9;&#x79CD;&#x97F3;&#x9891;&#x7F16;&#x7801;&#x683C;&#x5F0F;</td>
</tr>
</tbody>
</table>
<h2 class="mume-header" id="faq">FAQ</h2>

<p>1.Q: Uncaught Error: Site or Page Not Found : <a href="http://localhost/Decoder.data">http://localhost/Decoder.data</a><br>
A: &#x628A; decoder.data &#x6587;&#x4EF6;&#x653E;&#x5728;&#x6839;&#x76EE;&#x5F55;&#x4E0B;<br>
2.Q: &#x5B9E;&#x6D4B;&#x6027;&#x80FD;&#x548C;&#x7ED9;&#x7684;&#x6027;&#x80FD;&#x6570;&#x636E;&#x4E0D;&#x7B26;&#xFF0C;&#x4F7F;&#x7528;&#x4E86;chrome92&#x7248;&#x672C;&#xFF0C;&#x6CA1;&#x6709;&#x52A0;&#x8DE8;&#x57DF;&#x9694;&#x79BB;&#x5BFC;&#x81F4;<br>
A: http&#x5934;&#x589E;&#x52A0;&#x8DE8;&#x57DF;&#x9694;&#x79BB;&#xFF0C;Cross-Origin-Embedder-Policy: require-corp Cross-Origin-Opener-Policy: same-origin &#x5E76;&#x5728;https&#x73AF;&#x5883;&#x4E0B;&#x4F7F;&#x7528;&#x3002;</p>

      </div>
      
      
    
    
    
    
    
    <script>
var flowcharts = document.getElementsByClassName('flow')
for (var i = 0; i < flowcharts.length; i++) {
  var flow = flowcharts[i]
  try {
    var diagram = flowchart.parse(flow.textContent)
    flow.id = 'flow_' + i
    flow.innerHTML = ''
    diagram.drawSVG(flow.id)
  } catch (error) {
    flow.innerHTML = '<pre class="language-text">' + error.toString() + '</pre>'
  }
}
</script>
    
    
  
    </body></html>